Standardization in resource lambda-calculus 



Maurizio Dominici Simona Ronchi Delia Rocca 

Dipartimento di Informatica - Universita di Torino 
dominicimaurizioOgmail . com ronchiOdi .unito . it 

Paolo Tranquilli 

Dipartimento di Scienze dellTnformazione - Universita di Bologna 
tranquil@cs .unibo . it 

The resource calculus is an extension of the A-calculus allowing to model resource consumption. It 
is intrinsically non-deterministic and has two general notions of reduction - one parallel, preserving 
all the possible results as a formal sum, and one non-deterministic, performing an exclusive choice at 
every step. We prove that the non-deterministic reduction enjoys a notion of standardization, which 
is the natural extension with respect to the similar one in classical A-calculus. The full parallel 
reduction only enjoys a weaker notion of standardization instead. The result allows an operational 
characterization of may-solvability, which has been introduced and already characterized (from the 
syntactical and logical points of view) by Pagani and Ronchi Delia Rocca. 

1 Introduction 

The resource calculus (A r ) is an extension of the A-calculus allowing to model resource consumption. 
Namely, the argument of a function comes as a finite multiset of resources, which in turn can be either 
linear or reusable. A linear resource must be used exactly once, while a reusable one can be called ad 
libitum. In this setting the evaluation of a function applied to a multiset of resources gives rise to different 
possible choices, because of the different possibilities of distributing the resources among the occurrences 
of the formal parameter. We can define two kinds of reduction, according to the interpretation we want 
to give to this fact. The parallel reduction (which can be further divided in giant and baby) performs all 
the possible choices, and gives as result a formal sum preserving all the possible results, while the non- 
deterministic reduction at every step chooses non-deterministically one of the possible results. In case of 
a multiset of linear resources, also a notion of crash arises, whenever the cardinality of the multiset does 
not fit exactly the number of occurrences. Then the resource calculus is a useful framework for studying 
the notions of linearity and non-determinism, and the relation between them. A r is a descendant of the 
calculus of multiplicities, introduced by Boudol in Q, and it has been designed by Tranquilli ITTT1 in 
order to give a precise syntax for the differential A-calculus of Ehrhard and Regnier HI. A r can be used 
as a paradigmatic language for different kinds of computation. Usual A-calculus can be embedded in it. 
Forbidding linear terms but allowing non-empty finite multisets of reusable terms yields a purely non- 
deterministic extension of A-calculus, which recalls the one of De Liguoro and Piperno [3]. Allowing 
only multisets of linear terms gives the linear fragment of A r , used by Ehrhard and Regnier to give a 
quantitative account to A-calculus /3 -reduction through Taylor expansion 016]]. 

But to be effectively used, A r needs a clear operational semantics. In this paper we investigate 
the notion of standardization in it. Let us recall that a calculus has the standardization property when 
every reduction sequence can be rearranged according to a predefined order between redexes. Namely 
a reduction is standard with respect to a given order if at every reduction step the reduced redex is not 
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(a) Grammar of terms, bags, sums, expressions. 



Figure 1: Syntax of the resource calculus. 



a residual of a redex which, in the given order, precedes a previously reduced one. In the case of X- 
calculus, the standardization is based on the left-to-right order of redexes. 

In A r , as the elements of a multiset are not ordered, a notion of standardization would be based on a 
partial order between redexes. A first result, corresponding to a weak notion of standardization, has been 
proved by Pagani and Tranquilli [9 ], stating that the reductions of redexes inside reusable resources can 
always be postponed. We define a stronger partial order between redexes, and we prove that the non- 
deterministic reduction enjoys the standardization property with respect to it. Even though this order is 
not total, it is in fact undefined if and only if the two redexes live in different elements of a same multiset, 
so that any finer order would not be well-defined. This result allows us to complete the characterization 
of may-solvability, defined in (H. Let us stress that solvability is a key notion for evaluation, since it 
identifies the meaningful programs, and a clear notion of output result of a computation. Since this 
calculus is non-deterministic, two different notions of solvability arise, one optimistic (angelical, may) 
and one pessimistic (demoniac, must). In particular, in (U|7| a characterization of the may-solvability has 
been given, from a syntactical and logical point of view. Here we provide an operational characterization, 
through an abstract reduction machine, performing the non-deterministic reduction. The soundness and 
completeness of the machine with respect to the notion of may-solvability comes from the standardization 
property. 

Moreover we prove that the parallel reduction does not enjoy the same standardization property. 
Namely we show that in this case any order between linear redexes cannot be sound. This negative 
result is interesting, since it gives evidence to the deep difference between linear and non-deterministic 
reduction. 



2 Syntax 

The syntax of A''. Basically, we have three syntactical sorts: terms, that are in functional position, bags, 
that are in argument position and represent multisets of resources, and finite formal sums, that represent 



the possible results of a computation. Precisely, Figure [T(a)1 gives the grammar for generating the set A'" 
of terms and the set A* of bags (which are in fact finite multisets of resources A^) together with their 
typical metavariables. A resource can be linear (it must be used exactly once) or not (it can be used ad 
libitum, also zero times), in the last case it is written with a ! superscript. Bags are multisets presented 
in multiplicative notation, so that PQ is the multiset union, and 1 = [] is the empty bag: that means, 
PI = P and P Q = Q P. It must be noted though that we will never omit the dot •, to avoid confusion 
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( l{N/x):=0, 

\N ify = X, (Xy.M)(N/x) := Xy.M(Nfx), 

y(N/x):=\ ' ([M]-P)(N/x):=[M(N/x)}-P+[M]-P(N/x), 

otherwise, (MP){N/x) := M{N/x)P + MP{N/x), 

K ([M l ] ■P){N/x) := [M(N/x),M ] -P+W] -P(N/x) 



Figure 2: Linear substitution. In the abstraction case we suppose y ^ FV(iV) U {x}. 

with application. Sums are multisets in additive notation, with referring to the empty multiset, so that: 
M + = M and M + N = N + M. We use two different notations for multisets in order to underline the 
different role of bags and sums. 

An expression (whose set is denoted by A^) is either a term or a bag. Though in practice only sums 
of terms are needed, for the sake of the proofs we also introduce sums of bags and of expressions. The 
symbol Nat denotes the set of natural numbers, and Nat(A r ) (resp. Nat(A fo )) denotes the set of finite 
formal sums of terms (resp. bags). 

The grammar for terms and bags does not include sums in any point, so that in a sense they may 
arise only as a top level constructor. However, as an inductive notation (and not in the actual syntax) 
we extend all the constructors to sums as shown in Figure [T(b)| In fact, all constructors but the (•)' are, 
as expected, linear in the algebraic sense, i.e. they commute with sums. In particular, we have that is 
always absorbing but for the (•)' constructor, in which case we have [0 ! ] = 1. We refer to HUEl for the 
mathematical intuitions underlying the resource calculus. 

We adopt a-equi valence and all the usual A -calculus conventions as per fll . 

The pair reusable/linear has a counterpart in the following two different notions of substitutions: their 



definition, hence that of reduction, heavily uses the notation of Figure [1(b) 
Definition 1 (Substitutions). We define the following substitution operations. 

(i) A {N/x} is the usual A -calculus (i.e. capture free) substitution of N for x. It is extended to sums as 
in A{N/jc} by linearity in A. The form A{x + N/x} is called partial substitution. 

(ii) A(N/x) is the linear substitution defined inductively in Figure [2] It is extended to A(N/x) by 
bilinearity in both A and N. 

(hi) A({N^/x)), defined by A{(N/x)) :=A(N/x) and A((N [ /x)) :=A{N + x/x}, is the resource sub- 
stitution, and moreover A {(B/x)) , defined by A(([A^{ !) , . . . ,N^]/x)) =A({n[ ]) /x)) ■ ■ ■ {(N^/x)) (as- 
suming x £ FV(B)) is the bag substitution. 

Roughly speaking, the linear substitution corresponds to the replacement of the resource to exactly 
one linear occurrence of the variable. In the presence of multiple occurrences, all the possible choices are 
made, and the result is the sum of them. For example (y [x] [x] )(N/x) =y [N] [x] + y [x] [N] . In the case there 
are no free linear occurrences, then linear substitution returns 0, morally an error message. For example 
(Xy.y)(N /x) = Xy.(y(N /x)) = Xy.O = 0. Finally, in case of reusable occurrences of the variable, linear 
substitution acts on a linear copy of the variable, e.g. [x] (N/x) = [A^,x ! ]. 

The reductions of A r . A term context C[-J (or a bag context P[-]) is defined by extending the syntax 
of terms and bags by a distinguished free variable called hole and denoted by [•]. 

Notice that in contexts the order of holes cannot be truly established as bags are independent of 
order. So filling^ the k holes of a contexts by terms needs a bijective mapping a from { 1 , . . . , k } to hole 



1 We recall that hole substitution allows for variable capture. 
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occurrences in C[-], and C a [M,-] denotes the replacement of the holes by Mi, ...,M^ guided by this map. 
We can write also C[M,-J, by considering an implicit map. 

A (term, bag) context is simple if it contains exactly one occurrence of the hole. In this case we will 
write simply C\M\ for the result of filling of the hole with M. A simple context is linear if its hole is 
not under the scope of a () ! operator, and it is applicative if it has the hole not in a bag. As usual the 
(simple/applicative/linear) context closure of a relation R is the one relating C\t\ and C[?'J when t R t' 
and C is of the appropriate kind. 

We define two kinds of reduction rule, called parallel and non-deterministic. Moreover the parallel 
reduction can be further divided into baby-step and giant-step, the former being a decomposition of the 
latter. Baby-step is more atomic, performing one substitution at a time, while the giant-step is closer to 
A -calculus j6 -reduction, wholly consuming its redex in one shot. 

Definition 2 ( ifTTlfTOlD . (i) The parallel reductions are defined as follows: 

- The baby-step reduction is defined by the simple context closure of the following relation 
(assuming x not free in N): 

(Xx.M)l AM{0/i} {Xx.M)[N]-P ^ (Xx.M(N/x))P 
(Xx.M)[N ] ]-P \ (Xx.M{N + x/x})P 

- The giant-step reduction — > is defined by the simple context closure of the following relation: 

(Xx.M)P 4 M((P/x}) {0/x} 

(ii) The non-deterministic reduction is the relation M ^ N if and only if M A- N + A for some A. 

Notation 3. For any reduction A (the ones listed above and the ones to come), we denote by ^ its 
reflexive-transitive closure, p :M denotes a particular reduction sequence from M to N, and |p | its 
length. 

A r and A -calculus. In A -calculus, arguments can be used as many times we want, so it is easy to inject 
it in A'" through the following translation (.)*: 

{x)*=x, {Xx.Mf = Xx.(M)*, (MN)* = {M)*[{N)*-} 

On terms of A r which are translations of A -terms, the giant reduction becomes the usual j8 -reduction. 

3 Standardization 

In this section we will prove that the non-deterministic reduction enjoys a standardization property. As 
we recalled already in the introduction, the standardization property is based on an order relation between 
redexes. We can define it formally as follows: 

Definition 4. Let -< be an order on positions in terms (which is extended to an order on subterms of 
a given term). Suppose p is a reduction chain, and let M, and Rj be the i-th term and fired redex in p 
respectively. We say that p is ^-standard if for every i we have that Ri + \ is not the residual of a redex R' 
in Mi such that R' -< Rj. 



M. Dominici & S. Ronchi Delia Rocca & R Tranquilli 



5 



We will prove that non deterministic reduction in A r enjoys the standardization property with respect 
to the order -< r , which is the partial order on positions in A r terms that, intuitively, gives precedence to 
linear positions over non-linear ones, and then orders linear positions left-to-right, with the proviso that 
positions inside the same bag be not comparable. The formal definition follows. 

Definition 5 (Linear left-to-right order). For two subterms S\ and S2 inside the expression A, we say that 
Si -< r S2 in A if and only if any of the following happens: 

• S2 is a subterm of Si ; 

• Si is linear in A while S2 is not; 

• Si and S2 are both linear in A, A = MP, S\ is in M and S2 is in P. 

• Si and S2 are subterms of the same proper subexpression B of A, and Si -< r S2 in B; 
Example 6. Si -< r S2 in both Ax.x[S 2 ] [Si ] and Xx.x[S\ ] [S2] , while they are incomparable in Xx.x[S\ , S2] . 

Our starting point is the division of redexes in two classes, outer and inner. 

Definition 7 ((91). Let e £ {b,g,nd}. The outer £ -reduction ^> is the linear context closure of the 
£-steps given in Definitions [2] A non-outer £-reduction, called inner is defnoted by 

In other words, an outer reduction does not reduce inside reusable resources, so an outer redex {i.e. 
a redex for is a redex not under the scope of a (•)' constructor. In particular a term corresponding 
to a A -term has at most one outer-redex, which coincides with the head-redex. Pagani and Tranquilli 
stated in some sense a weak standardization property for the giant reduction, proving that inner redexes 
can always be postponed. Their result can easily be extended to other reductions, in particular to the 
non-deterministic one. 

Theorem 8 ([9 ]). Let e G {b,g, nd}. M 4 A implies M °4 A' and A' % A. 

We introduce now a further classification between outer redexes. 
Definition 9. The set of leftmost redexes Jzf (M) of a term Mora bag P are defined inductively by: 



In regular A -calculus, the set Jzf (M) is at most a singleton, and X r -standardness collapses to the 
regular notion of left-to-right order of redexes. 

Fact 10. Redexes in Jzf (M) are exactly the -< r -minimal elements among all redexes of M. 

In the following, we will consider in particular the non-deterministic reduction. So, let us introduce 
some notation. 

Notation 11. Let M 1 ^? N. M ^ N denotes that the reduction fires a redex in Jz?(M), while we write 
M ./V if the redex is not a leftmost one. Moreover M N and M ^ N will be short for for M n ^$ N 
and M n ^$ N respectively. 

Lemma 12. We have the following facts on non-leftmost reduction. 



• p : Xx.M ^> N if and only ifN = Xx.M' and p' : M ^> M' with |p | = \p'\; 

• p:MP =^ N if and only ifN = M'P', p' : M ^> M' and p" : P ^ P' with \p \ = |p'| + |p 



££{x) := 0, 
Jf(kxM) := Jgf (M) 



'{MP} 

^{MP) := \ Jzf (M) 



if M = Xx.M' , JSf(l) 
otherwise, if Jzf (M) + Jz?([M ! ] P 
otherwise Jf([M]-P) 







J5f(P), 

^(M)U^(P) 
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• p : [M] • P ^A q if an d on \ y ifQ = [M'\ ■ P', p' : M ^> M' and p" : P P' with |p | = 

Ip'I + Ip"I; 

• p : [M ! ] -P ^A 2 i/arcd only ifQ = [M ! ] -P' and p" : P ^?A P' with \p\ = \p"\. 

The proof of standardization is based on an inversion property between outer redexes, saying that 
a not-leftmost reduction followed by a leftmost one can always be replaced by a leftmost followed by 
an outer. This is the upcoming ILemma 131 In order to get it we first prove the following intermediate 
properties. 

Lemma 13. If 0^0' then ML' e 0'((Q/x)) {0/x} 3L G 0{(Q/x)) {0/x} such that L A L'. 

Proof We will prove that ML' G 0'({Q/x))3L G 0{(Q/x)) such that L A L'. Then the statement of the 
lemma follows easily. By induction on O. 

Case 1. O = x and O = y are not possible. 

Case 2. O = Xy.M. By inductive hypothesis. 

Case 3. O = {XyM)P. There are three cases: Xy.M ^ XyM 1 , P A P', (Xy.M)P AO's M((P/y)) {0/y}. 
Let M A M'. {Xy.M)P{{Q/x))=Z QuQl {{Xy.M){{Q l /x))){P{{Q 2 /x))),where Q x , Q 2 range over 
all the possible decomposition of Q into two parts, counting the reusable resources with all the 
possible multiplicities. This means that in case Q \,Q% are considered two different subterms 
also in case they are syntactically equal. By inductive hypothesis, for all L' G (Xy.M')((Qi/x)) 
there is L £ (Xy.M)((Qi/x)) such that L A L', and the result follows by transitivity of G. The 
case P A P' is similar. 

Let (Xy.M)P A O' G M{(P/y}) {0/y}. Then we have that the substitution (Xy.M)P((Q/x)} is 
equal to the sum Y i Q l> Q 2 (Xy.M((Qi/x)))(P((Q2/x))), where Qi,Q 2 range as before. Since each 
component of this sum is a redex (the substitutions do not modify the external shape of the 
terms), we can reduce each redex, so obtaining that for all L G {Xy.M{{Q\/x))){P{{Q%/x))), 
LAL'e M({Qi/x))({P({Q 2 /x))/y)) {0/y}. On the other side, M((P/y)) {0/y} ((Q/x)) is equal 
to the sum £ Ql)G2 M((gi/;c))((P ((&/*))/)>)) {0/y}, and the proof is done. 

Case 4. = MP and O' = M'P or O = MP and O' = MP'. All by inductive hypothesis. □ 

Lemma 14. IfQ^Q' then ML' G 0{(Q'/x)) {0/x} 3L G 0{(Q/x)) {0/x} such that L A- L'. 

Proof. By induction on Q. Q cannot be 1 as it would be normal. 

If Q = [H] P then 0{(Q/x)) {0/x} = 0(H/x)({P/x)) {0/x}. We proceed by cases: 

Case 1. The reduction is on P, i.e. [H] P A [H] P'. For all N G 0(H/x), N{(P/x)) A N({P'/x)). Then 
we have by induction that for all L G N{{P/x)) {0/x} there is L' G N((P'/x}} {0/x} such that 
L A L'. So the result follows. 

Case 2. The reduction is on H, i.e. [H] ■ P A [H'\ ■ P). Let us set 0{H/x) {(P/x)) {0/x} = (Oi + ... + 
Ok)((P/x)} {0/x}, where H occurs in all Oj (1 < j < k), since the substitution is linear. Let 
Oj ^ 0\ + ... + C?m by reducing the occurrence of H in it. So A 0\ (1 < i < m y ), and, by 
ILemma 131 for all L' G 0{({P/x)) {0/x}, there is L G Oj((P/x)) {0/x} such that L A L' . Since 
G 0(#/jc) and Oj G 0(H'/x), the proof follows. 

If 2 = ' P the reduction on P, and the case is similar to the first case of the previous point. □ 
Lemma 15 (Inversion). M^fM'^N implies M 4 M" n A iV, for some M". 
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Proof. We proceed by induction on M. 

Let M = Xy.{Xx.O)QP\...Pj...P n , so Jz?(M) = {(Xx.O)Q). Non leftmost reductions on M can be done in 
0, in Q or in Pj (1 < j < «). We precede by cases: 

Case 1. The reduction is on Pj(l < j < n).]. Let Pj A Pj + S. We have that 

M Ay. (Ax. 0) . . .Pj . . .P„ A Xy.O({Q/x}) {0/x} P x . . .Pj . . .P n . 
Moreover, by reducing the leftmost redex 

M A Xy.O{(Q/x)) {0/x}P l ...P j ...P n = Xy.(Oi + ... + O k )P 1 ...P j ...P„, 

so that 

M A Xy.O h P 1 ...P J ...P„ A Xy.O h P 1 ...P' j ...P n 

for all 1 < h < k. 

Case 2. The reduction is on Q. Let 2 A Q' and let M ^? Ay . (Xx.O) Q'Pi . . .P„ ^ Ay .MA .../>„, where M 
is such that M € 0((Q'/x)) {0/x}. Moreover, by reducing the leftmost redex, we also have 
the reduction M A Xy.O((Q/x)) {0/a}Pi...P„. By ILemma 141 Q A Q' implies that for all 
L' € 0((Q'/x)) {0/x}, there exists L G 0((Q/x}) {0/x} such that L A U. So there is M G 
0((Q/x)) {0/x} such that M A Ay-MP^.p, A Ay-MA.-.P,,. 

Case 3. The reduction is in O. Let A 0', and let M^f Xy.{Xx.O')QPi...P n A XyMP x ...P n , where M 
is such that M € 0'((Q/x}) {0/x}. Again if we reduce the leftmost redex, we have the reduction 
M A Xy.O({Q/x)) {0/x}P l ...P n . 0^0' implies;, by ILemma 13l VL' € 0'{(Q/x)) {0/x} ,3L G 
0({Q/x)) {0/x} such that L A L'. So there is M € 0{(Q/x)} {0/x} such that we can compose 
the reductions M A XyMP { ...P n A Ay.MPj ...P„. 

Let M = Ay.xPi ...P„, and let p P/ and P ; - A P'-. In case / ^ j, the proof is trivial. In case i = j the 
proof is by induction on p. □ 

Corollary 16. If p : M A M' then there areo:M^ M" and % : M" A2i> M' with \o\ + \n\ = \p\. 
Lemma 17. 

( i) Given p : M "A* N and a : ./V A L, then po :M A Lis -< r -standard if and only if o is. In particular 
every chain of leftmost reductions is -< r -standard. 

(ii) Given p : M A ./V and O : ./V A L, then po : M*A* L is -< r -standard if and only if both p and O are. 
Proof. The result follows easily from the definition of -< r . □ 

Now we can prove that the non-deterministic outer reduction is ^-standard. 

Lemma 18 (Non-deterministic outer standard reduction). IfM^N, then there is a -< r -standard non- 
deterministic outer reduction from M to N. 

Proof. We reason by induction on the pair (p,s), where p = |p| is the length of the reduction sequence 
p : M A- N, and s is the number of symbols in M. By Corollary 16 there is a reduction G/ : M"A M' 
and o r : M' ~ llm *> N with |c/| + \o r \ = |p| = p. If |<7/| > then inductive hypothesis applies to o r , 
giving -< r -standard o' r :M' -A N, which gives that 0[0' r : M A ./V is -< r -standard by ILemma 171 In case 
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o r : M > N is the whole reduction, the proof is by cases on M. The only non-obvious case is when 
M = LP: bv lLemma 12l we have N = L'P' and p' : L ^> Jj and p" : P ^ P' . We can apply inductive 
hypothesis to both as \p'\ + \p"\ = \p r \, and get LP ~ llm *> L'P ^> L'P'. Now assuming that this is not 
-< r -standard leads to a contradiction to the definition at the seam, since all linear positions in L" are -< r 
with respect to those in P. □ 

In order to prove that also inner reductions can be standardized, we need to introduce the notion of 
outer shape of a term. 

Definition 19. The outer shape £(M) [•] of a term M is a context that is M with holes replacing all 
exponential arguments of M's bags. 

Formally, extending the definition to bags, we define £( .)[•] inductively as follows. 

£(x)U =x, l{XxM)li=Xxl{M)U, £(MP)U=£(M)B£(P)l-l 

t(i)U = i, £([m] -p)H = [£(M)ij}-£(p)ii £(m-p){-j = [[-] ! MPM 

Property 20. 

(i) M ^ N if and only if £(M)[-] = •£(#)[•], and there are k terms M\ and k terms N- such that 
Af = £(M) u \M' i \,N = £{M) a \N' i \ and M[ ^ Nj for each i. 

(ii) If M = £(M) a \M' i \ and p,- : Af? ^ Mf are standard, then there is a standard p' : M ^ £(M) a {M^\. 
Proof. 

i) The if direction is a direct consequence of how i is defined and of context closedness of the 
reduction. We thus move to the only if direction. 

First, let us show that the property to prove is preserved by composition of reduction chains. 

Suppose M^N ii> <9 with M = £(M)[M<], N = £(M) ai [Nj] = £(M) a2 [N!'] and O = £(M) fl3 [^]. 
We can suppose a\ = a% by re-indexing (namely using £(N) ai [N"-i, J and £(0)j [N"- 1( .J with 

a' 3 = <33 oaj 1 oflj). So we just forget the bijections employed, and then we have by hypothesis 
M\ N- = N" ^ 0\, which is what is needed. 

Now, we can prove the property by reducing to the case of a single inner reduction, as composing 
multiple ones of them preserves the property. 

Take M A N: the result follows by a straightforward induction on how the reduction is defined. 

ii) The idea is that the reductions in the subterms can be freely rearranged. 

Let us reason by generalizing to expressions and by structural induction on A. 
Case 1. A = x or A = 1 : nothing to prove. 

Case 2. A = Xx.N: straightforward application of inductive hypothesis. 

Case 3. A = NP, with £(A){-j = £{N)[-}£(P)H: we can partition M\ into what goes in £(N){-j and 
what goes in t(P)[-}. We can suppose that A = (£{N)[M' V . . . ,M' h ])(£(P)[M' h+l , . . . ,M' k }) 
without loss of generality, and by inductive hypothesis get standard a : N ^ N' and p : 
P^P' (with N' and P' the correct pluggings of £(N) and £(P)). 

Now, if we reduce A = NP ^> N'P ^> N'P' following first a and then p , the resulting 
reduction must be standard as all positions in P axe greater than those in Af according to -< r . 

Case 4. A = [N] ■ P: exactly as above, but without any constraint on the order in which the reductions 
are composed. 
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Case 5. A = [A^ 1 ] P, with 1(A) = [[■]'] ■£(P)lf. suppose that Mj = N and P = £(P)[M' 2 ,- ■ ■ ,M' k ]. By 
inductive hypothesis we have a standard p : P ^ P' = £(P)[M'/]^ =2 , and as positions in [A^ ! ] 
and non-linear positions in P are incomparable, we can freely combine the reductions on M[ 
and P to get a standard one. □ 

Now we are able to show the desired result. 
Theorem 21 (Standardization). IfM n -^$ M', then there is a -< r -standard chain from M to M'. 

Proof. By structural induction on M', the term where the reduction ends. First, applying |Theorem"8l we 
get a : M ^> M" and p : M" M'. Now we strive to obtain two standard chains a' : M ^> M" and 
pi . j^ii ndi*^ j^i tQ Q ^ ta j n c hain a'p' which is standard by lLemma 171 The existence of a standard o' 
is assured directly by lLemma 181 so we need to concentrate on finding p'. By using Property 20(i)| we 



get M" = t{M') {N u ...,N k },M' = i(M') {N[,... ,NjJ and p ; : N t ^ N-. As all N[ are structurally strictly 
smaller than M', we can apply inductive hypothesis on each p, and get standard p- : A^, ^-A Nj. Then 



using Property 20(ii) we can glue back those reductions into the standard reduction p' : M" ^ M' . □ 



Example 22. Let / = Xx.x, M l = 7[((Axy..x)[/ ! ] [/'])■], M 2 = /[/'], and let M = Xx^M^ ,M 2 ! ]. The fol- 
lowing reduction is standard: M { = 7[((Ax3;.x)[/ ! ][/ ! ]) ! ] ^ (Xxy.x)[I ] }[I ] \ ^ (Xy.I)[I ] \ ^ /. As M 2 4 /, 
the following is standard too 

Ax.x[(/[((Ax);.x)[/ ! ][/ ! ]) ! ]) ! ,(/[/ ! ]) ! ]4Ax.x[((Ax);.x)[/ ! ][/ ! ]) ! ,(/[/ ! ]) ! ]4 

Xx.x[{{Xxy.x)[I [ }[I-})\l-} ^ Xx.x[({Xy.I)[I-})- ,1-} ^ Xx.x[l\l\ 

Let us notice that, as opposed to the weak form of standardization given in ITheorem~8l the -< r - 
standardization does not hold for parallel reduction. A counterexample is the following. 

Example 23. Let Iq and 1\ denote two occurrences of the identity Xx.x, and let M = /o[/i[x ! ,y]] A 
To [x] + Io \y] -^-x + Iq [y] by reducing the inner redex first. But reducing the leftmost redex first we obtain 
M A- 1\ [x\y'\ A x + y. So the previous result cannot be obtained by a standard reduction. 



4 Solvability Machine 

The standardization result proved in the previous section allows us to design an abstract reduction ma- 
chine characterizing the may-solvable terms in A r . A term of A -calculus is solvable whenever there is 
a outer-context reducing it to the identity HI. In the resource calculus, terms appear in formal sums, 
so (at least) two different notions of solvability arise, related to a may and must operational semantics, 
respectively. We will treat the former only. 

Definition 24. A simple term M is may-solvable whenever there is a linear applicative-context C[-J 
such that C[M] ^> /. 

May-solvability has been completely characterized from both a syntactical and logical point of view 
in lUl. Syntactically, a term M is may-solvable if and only if it is may-outer normalizable. An expression 
is an outer normal form (onf) if it has no redex but under the scope of a ( ) ' , and consequently a term M 
is may-outer normalizable if and only if M 1 ^ N, where Af is a onf (N is called a monf of M). Logically, 
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Standardization in resource lambda-calculus 



, M !"f , (A) Miiinonf ^ *M il^jO (W) 
AxM^AxM' V 7 1 ; xP x ...P n AndxP[...P' m K ' 

M{0/x}P l ...P m ^ nd M' M (N/x) =M' + A (Xx.M')PP y ...P m ^ nd M" 

(Xx.M) 1 A • • -Pm Ud M' [ ' {XX.M) [N] ■ PPi . . .P m )l nd At" [P ' 

M{N + x/x} =M' + A (Xx.M')PP x ...P m ^ nd M" 



(Xx.M)\N\PP,...P m UnjM" 
(a) The ND reduction machine. 



M ty„d N PUP' PUP' ( lb) 



\U^ K ' [M]-PU[N]-P' w [M] -P ij-b [M] -P' 

(b) The auxiliary B machine 



a particular intersection type assignment system has been defined, typing all and only the may-solvable 
terms. 

We now will complete the job, characterizing may solvability from an operational point of view. The 
following property is obvious. 

Property 25. M is in onf if and only if Jz? (M) = 0. 

The abstract reduction machine (called A^D-machine) proves statements of the shape M Ud N, where 
M,N are simple terms and N is a onf. The ND-machine uses an auxiliary machine, the B-machine, 
performing the reductions on bags. The two machines are shown in Figure |4] 

Some comments are in order. First of all, the machine performs the baby outer reduction, on a 
leftmost redex. Rules (A), (end) and (0) are self-explanatory. Rule (head) implements the definition 
of monf; note that in this rule the order in which the arguments are reduced does not matter. Non- 
determinism appears in rules (j8) and (!j3). Indeed, if the result of the substitution is a sum, one of its 
addends is randomly chosen. The auxiliary machine B performs the reductions on bags. Note that the 
rule (\b) implements the notion of outer-reduction. Remember that is not a term, so it can be neither 
an input nor an output of the machine. So in rules (0), (/$) and (!j8) the machine transition is undefined 
if the result of the substitution is 0. We will write M ff„d to denote that for any run of the machine on M 
either it does not stop or it is undefined. 

Example 26. (Azy.;y)[jt] f|W- In f act , trying to apply rule j3, the machine needs to compute (Xy.y) (x/z), 
which is equal to 0, so the premises of the rule are not satisfied. 

(Ajc.je[jc ! ])(Ajc.je[je ! ]) f|w. In fact, the machine on this input does not stop. Notice that this term corre- 
sponds to an unsolvable term in the A -calculus. 

Let F = Xxy.y. Then (Ax.y[x] [x]) [F,I] [Im] reduces non deterministically to y[F] [I] +y[I] [F]. It is easy to 
check that there are two machine computations such that in one (Ax.y[x] [jt])[F,/] JJ-nd y[F] [I] while in the 
other (Xx.y[x][x})[F,I] W[/][F]. 

(Xx.y[x ] ])[I- ,F ] ] A by reducing the leftmost redex. The unique machine computation for this 

input gives (Xx.y[x [ ])[I l ,F l ] Ud y[i [ ,F 1 }. 

Theorem 27. 

( i) ( Soundness )IfM ij. ni j N then M 1 ^ N, and N is a onf. 

(ii) ( Completeness) Let M be may-outer-normalizable and let N be a monf of M. There is a machine's 
computation proving M JJ-nd N', where N 1 is a monf ofM and N' =^ N. 
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Proof (sketch). Point (0) is proved by mutual induction on the rules of the two machines. Point (O is an 
immediate consequence of the -^-standardization property. □ 

Acknowledgements. We would like to thank Michele Pagani for his interesting and useful suggestions. 
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